# Management and analysis of physics datasets, Part. 1

Second Laboratory

Stefano Pavinato 27/11/2018



### Outline



- 1 Laboratory Introduction
- 2 Simulation Testbenches
- 3 Combinational Logic Circuits
  - Multiplexer
  - Adder
  - Adder: common solutions
- 4 Homework

### Outline



- 1 Laboratory Introduction
- 2 Simulation Testbenches
- 3 Combinational Logic Circuits
  - Multiplexer
  - Adder
  - Adder: common solutions
- 4 Homework

### Goals



- Exploit the simulation tool.
- Become familiar with components and *port map*.

### VHDL naming convention



| Signals/components     | Name              |
|------------------------|-------------------|
| Clock                  | clk               |
| Reset                  | rst               |
| Input Port             | port_in           |
| Output Port            | port_out          |
| VHDL file name         | entityname.vhd    |
| Test bench file name   | tb_entityname.vhd |
| Signal between 2 comps | sign_cmp1_cmp2    |
|                        |                   |

### Outline



- 1 Laboratory Introduction
- 2 Simulation Testbenches
- 3 Combinational Logic Circuits
  - Multiplexer
  - Adder
  - Adder: common solutions
- 4 Homework

#### Simulation - reasons



- Once written the code describing the component, it is necessary check its working.
- Regarding on not trivial projects, simulation is a crucial and mandatory step in the development of the project: testing any firmware on hardware without simulation has to be avoided because it is unsafe and very time consuming.
- So with the simulation we are going to stimulate the inputs and check the accuracy of the outputs.

### Testbench (1)



- To simulate the behavior of the code written, we have to make a VHDL file, in order to define the input stimuluses and so check the output evolution.
- This file is a **testbench**.
- The component to be tested (the "Hello World" top) has to be instantiated and the processes where the input signals values are described have to be written.
- The testbench does not have input and output ports in its entity declaration.

### Testbench (2)



- 1 Add sources;
- Check "Add or create simulation sources";
- 3 Next  $\rightarrow$ ;
- 4 Check "Create File";
- 5 File name: "tb\_top";
- 6 OK  $\rightarrow$ .
- **7** Finish  $\rightarrow$ ;
- 8 OK  $\rightarrow$ .
- 9 Yes  $\rightarrow$ .

### Testbench (3)



Simulation Sources  $\rightarrow$  sim\_1  $\rightarrow$  tb\_top.



### Testbench (4)



```
entity tb top is
-- Port ( );
end tb top;
architecture Behavioral of tb_top is
component top is
  Port (btn in: in std logic:
        led out : out std logic );
end component;
signal btn, led : std logic;
begin
uut : top port map (btn_in => btn, led_out => led);
pl : process
   begin
      btn <= '0':
      wait for 200 ns;
      btn <= '1';
      wait for 200 ns:
     btn <= '0';
      wait for 200 ns:
   end process:
end Behavioral;
```

### Testbench (5)



- Declaration of the component to test. Suggest: copy/paste from top.vhd the piece of the code between entity and end top; and substitute component for entity.
- 2 Declaration of the internal signals. They are used to connect the component under test (Unit Under Test) to the stimulus.
- 3 Instantiation of the component. Each port is connected through the internal signals.
- 4 Definition of the input stimuluses. It is very very good practice check each input combination.

### Simulation (1)



 $\mathsf{SIMULATION} \to \mathsf{Run} \ \mathsf{Simulation} \to \mathsf{Run} \ \mathsf{Behavioral} \ \mathsf{Simulation}.$ 



Inside the red rectangle there are the zoom options.

### Simulation (2)



- With the Behavioral Simulation we check that the component works as expected.
- The output changes happen simultaneously to the input changes. This kind of simulation check the behavior of the code written without considering the delays of a real electronic system.

### Simulation (3)



- With the same testbench used before we are going to check the behavior of the component afterward the implementation step. Here the simulation evaluates the logic gates delay and the interconnections delays;
- SIMULATION  $\rightarrow$  Run Simulation  $\rightarrow$  Run Post-Implementation Timing Simulation  $\rightarrow$  Yes;



If this simulation is successfully, almost always the project works in the hardware too.

### Outline



- 1 Laboratory Introduction
- 2 Simulation Testbenches
- 3 Combinational Logic Circuits
  - Multiplexer
  - Adder
  - Adder: common solutions
- 4 Homework

### Reusability of the code



- The next examples show you as re-use the code already written.
- The code in this course is reused in the form of **components**.
- The components are then located in the top code.
- You'll can see a construction of a hierarchical design.

#### How to use a component?

- 1 Declaration:
- 2 Instantiation.

### Outline



- 1 Laboratory Introduction
- 2 Simulation Testbenches
- 3 Combinational Logic Circuits
  - Multiplexer
  - Adder
  - Adder: common solutions
- 4 Homework

## Multiplexer 2-1



| Α | В | S | Υ |
|---|---|---|---|
| 0 | 0 | 0 | 0 |
| 1 | 0 | 0 | 1 |
| 0 | 1 | 0 | 0 |
| 1 | 1 | 0 | 1 |
| 0 | 0 | 1 | 0 |
| 1 | 0 | 1 | 0 |
| 0 | 1 | 1 | 1 |
| 1 | 1 | 1 | 1 |



### Mux 2-1 Code



```
entity mux2l is
  Port (a in : in std logic;
        b in : in std logic;
        sel_in : in std_logic;
        y out : out std logic);
end mux21:
architecture rtl of mux21 is
begin
process (a_in, b_in, sel_in) is
begin
  if sel in = '0' then
      y out <= a in;
   else
     y out <= b in;
   end if:
end process;
end rtl:
```

### Mux 2-1 Schematic





#### Mux 2-1 Testbench



```
lentity tb mux21 is
-- Port ( );
end tb mux21;
architecture Behavioral of tb mux21 is
component mux21 is
  Port (a in : in std logic;
        b in : in std logic:
        sel in : in std logic;
        y out : out std logic);
end component;
signal a,b,sel,y : std logic;
begin
 uut : mux21 port map (a in => a, b in => b, sel in => sel, y out => y);
 p sel : process
 beain
    sel <= '0'; wait for 200 ns;
    sel <= '1': wait for 200 ns:
 end process:
 p ab : process
 begin
    a <= '0': b <= '0': wait for 125 ns:
    a <= '0': b <= '1': wait for 125 ns:
    a <= '1'; b <= '0'; wait for 125 ns;
    a <= '1': b <= '1': wait for 125 ns:
 end process:
end Behavioral:
```

### Mux 2-1 Behavioral Simulation



|        |       | 549.020 ns |        |        |  |        |        |  |  |
|--------|-------|------------|--------|--------|--|--------|--------|--|--|
| Name   | Value | 0 ns       | 200 ns | 400 ns |  | 600 ns | 800 ns |  |  |
| le a   | 0     |            |        |        |  |        |        |  |  |
| la b   | 0     |            |        |        |  |        |        |  |  |
| lo sel | 0     |            |        |        |  |        |        |  |  |
| la y   | 0     |            |        |        |  |        |        |  |  |
|        |       |            |        |        |  |        |        |  |  |

# Multiplexer 4-1 (1)



| Α | В | С | D | S0 | S1 | Υ | Α | В | С | D | S0 | S1 | Υ |
|---|---|---|---|----|----|---|---|---|---|---|----|----|---|
| 0 | 0 | 0 | 0 | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0  | 1  | 0 |
| 1 | 0 | 0 | 0 | 0  | 0  | 1 | 1 | 0 | 0 | 0 | 0  | 1  | 0 |
| 0 | 1 | 0 | 0 | 0  | 0  | 0 | 0 | 1 | 0 | 0 | 0  | 1  | 0 |
| 1 | 1 | 0 | 0 | 0  | 0  | 1 | 1 | 1 | 0 | 0 | 0  | 1  | 0 |
| 0 | 0 | 1 | 0 | 0  | 0  | 0 | 0 | 0 | 1 | 0 | 0  | 1  | 1 |
| 1 | 0 | 1 | 0 | 0  | 0  | 1 | 1 | 0 | 1 | 0 | 0  | 1  | 1 |
| 0 | 1 | 1 | 0 | 0  | 0  | 0 | 0 | 1 | 1 | 0 | 0  | 1  | 1 |
| 1 | 1 | 1 | 0 | 0  | 0  | 1 | 1 | 1 | 1 | 0 | 0  | 1  | 1 |
| 0 | 0 | 0 | 1 | 0  | 0  | 0 | 0 | 0 | 0 | 1 | 0  | 1  | 0 |
| 1 | 0 | 0 | 1 | 0  | 0  | 1 | 1 | 0 | 0 | 1 | 0  | 1  | 0 |
| 0 | 1 | 0 | 1 | 0  | 0  | 0 | 0 | 1 | 0 | 1 | 0  | 1  | 0 |
| 1 | 1 | 0 | 1 | 0  | 0  | 1 | 1 | 1 | 0 | 1 | 0  | 1  | 0 |
| 0 | 0 | 1 | 1 | 0  | 0  | 0 | 0 | 0 | 1 | 1 | 0  | 1  | 1 |
| 1 | 0 | 1 | 1 | 0  | 0  | 1 | 1 | 0 | 1 | 1 | 0  | 1  | 1 |
| 0 | 1 | 1 | 1 | 0  | 0  | 0 | 0 | 1 | 1 | 1 | 0  | 1  | 1 |
| 1 | 1 | 1 | 1 | 0  | 0  | 1 | 1 | 1 | 1 | 1 | 0  | 1  | 1 |
| 0 | 0 | 0 | 0 | 1  | 0  | 0 | 0 | 0 | 0 | 0 | 1  | 1  | 0 |
| 1 | 0 | 0 | 0 | 1  | 0  | 0 | 1 | 0 | 0 | 0 | 1  | 1  | 0 |
| 0 | 1 | 0 | 0 | 1  | 0  | 1 | 0 | 1 | 0 | 0 | 1  | 1  | 0 |
| 1 | 1 | 0 | 0 | 1  | 0  | 1 | 1 | 1 | 0 | 0 | 1  | 1  | 0 |
| 0 | 0 | 1 | 0 | 1  | 0  | 0 | 0 | 0 | 1 | 0 | 1  | 1  | 0 |
| 1 | 0 | 1 | 0 | 1  | 0  | 0 | 1 | 0 | 1 | 0 | 1  | 1  | 0 |
| 0 | 1 | 1 | 0 | 1  | 0  | 1 | 0 | 1 | 1 | 0 | 1  | 1  | 0 |
| 1 | 1 | 1 | 0 | 1  | 0  | 1 | 1 | 1 | 1 | 0 | 1  | 1  | 0 |
| 0 | 0 | 0 | 1 | 1  | 0  | 0 | 0 | 0 | 0 | 1 | 1  | 1  | 1 |
| 1 | 0 | 0 | 1 | 1  | 0  | 0 | 1 | 0 | 0 | 1 | 1  | 1  | 1 |
| 0 | 1 | 0 | 1 | 1  | 0  | 1 | 0 | 1 | 0 | 1 | 1  | 1  | 1 |
| 1 | 1 | 0 | 1 | 1  | 0  | 1 | 1 | 1 | 0 | 1 | 1  | 1  | 1 |
| 0 | 0 | 1 | 1 | 1  | 0  | 0 | 0 | 0 | 1 | 1 | 1  | 1  | 1 |
| 1 | 0 | 1 | 1 | 1  | 0  | 0 | 1 | 0 | 1 | 1 | 1  | 1  | 1 |
| 0 | 1 | 1 | 1 | 1  | 0  | 1 | 0 | 1 | 1 | 1 | 1  | 1  | 1 |
| 1 | 1 | 1 | 1 | 1  | 0  | 1 | 1 | 1 | 1 | 1 | 1  | 1  | 1 |

## Multiplexer 4-1 (2)





### Mux 4-1 Code

'entity mux4l is

end mux41:

Port (a\_in : in std\_logic; b\_in : in std\_logic; c\_in : in std\_logic; d in : in std\_logic;

y out : out std logic);

sel in : in std logic vector (1 downto 0):



```
architecture rtl of mux41 is
                               DECLARATION
component mux21 is
  Port (a in : in std logic:
       b in : in std logic;
       sel in : in std logic:
       v out : out std logic):
end component;
signal y ml m3 : std logic;
signal v m2 m3 : std logic:
                                               INSTANTIATIONS
begin
ml : mux21 port map(a in => a in,
                                 b in => b in,
                                                sel_in => sel_in(0), y_out => y_ml_m3);
m2 : mux21 port map(a in => c in.
                                                sel in => sel in(0), v out => v m2 m3):
                                 b in => d in.
m3: mux21 port map(a in => y m1 m3, b in => y m2 m3, sel in => sel in(1), y out => y out);
end rtl:
```

### Mux 4-1 Schematic





#### Mux 4-1 Constraints



```
I## Buttons
set property -dict { PACKAGE PIN D9
                                       IOSTANDARD LVCMOS33 } [qet ports { a in }]; #IO L6N TO VREF 16 Sch=btn[0]
set property -dict { PACKAGE PIN C9
                                      IOSTANDARD LVCMOS33 } [get ports { b in }]; #IO L11P T1 SRCC 16 Sch=btn[1]
set property -dict { PACKAGE PIN B9
                                       IOSTANDARD LVCMOS33 } [qet ports { c in }]; #IO L11N T1 SRCC 16 Sch=btn[2]
                                       IOSTANDARD LVCMOS33 } [get ports { d in }]; #IO L12P T1 MRCC 16 Sch=btn[3]
set property -dict { PACKAGE PIN B8
## Switches
set property -dict { PACKAGE PIN A8
                                       IOSTANDARD LVCMOS33 } [qet ports { sel in[0] }]; #IO L12N T1 MRCC 16 Sch=sw[0]
set property -dict { PACKAGE PIN Cll
                                       IOSTANDARD LVCMOS33 } [get ports { sel in[1] }]: #IO L13P T2 MRCC 16 Sch=sw[1]
## RGR LEDS
set property -dict { PACKAGE PIN El IOSTANDARD LVCMOS33 } [qet ports { y out }]; #IO L18N T2 35 Sch=led0 b
```

### Outline



- 1 Laboratory Introduction
- 2 Simulation Testbenches
- 3 Combinational Logic Circuits
  - Multiplexer
  - Adder
  - Adder: common solutions
- 4 Homework

#### Adder 1 bit



| Α | В | Cin | Yout | Cout |           |
|---|---|-----|------|------|-----------|
| 0 | 0 | 0   | 0    | 0    | 0+0+0=0   |
| 1 | 0 | 0   | 1    | 0    | 1+0+0 = 1 |
| 0 | 1 | 0   | 1    | 0    | 0+1+0=1   |
| 1 | 1 | 0   | 0    | 1    | 1+1+0 = 2 |
| 0 | 0 | 1   | 1    | 0    | 0+0+1=1   |
| 1 | 0 | 1   | 0    | 1    | 1+0+1 = 2 |
| 0 | 1 | 1   | 0    | 1    | 0+1+1 = 2 |
| 1 | 1 | 1   | 1    | 1    | 1+1+1 = 3 |



#### Add1b code



```
Library IEEE;
use IEEE.STD LOGIC 1164.ALL;
-- Uncomment the following library declaration if using
-- arithmetic functions with Signed or Unsigned values
--use IEEE.NUMERIC STD.ALL;
entity adder_lb is
  Port (a in : in std logic;
        b in : in std logic;
        c in : in std logic;
        y out : out std logic;
        c out : out std logic);
 end adder 1b;
 architecture rtl of adder 1b is
 begin
 y out <= a in xor b in xor c in;
c_out <= (a_in and b_in) or (a_in and c_in) or (b_in and c_in);
 end rtl:
```

### Adder 4 bit





#### Add4b Code



```
entity adder_4b is
Port (a_in : in std_logic_vector(3 downto 0);
    b_in : in std_logic_vector(3 downto 0);
    y_out : out std_logic_vector(4 downto 0) );
end adder_4b;
architecture rtl of adder_4b is
```

# component adder\_lb is Port (a in : in std\_logic; b\_in : in std\_logic; c\_in : in std\_logic; y\_out : out std\_logic; c\_out : out std\_logic; end component:

#### **DECLARATION**

```
signal v al a2, v a2 a3, v a3 a4 : std logic;
```

#### begin

#### INSTANTIATION

end rtl;

### Add4b Schematic





#### Add4b Constraints



```
## Ruttons
                                       IOSTANDARD LVCMOS33 } [get ports { a in[0] }]: #IO L6N TO VREF 16 Sch=btn[0]
set property -dict { PACKAGE PIN D9
                                       IOSTANDARD LVCMOS33 } [get ports { a in[1] }]: #IO L11P TI SRCC 16 Sch=btn[1]
set property -dict { PACKAGE PIN C9
                                       IOSTANDARD LVCMOS33 } [get ports { a in[2] }]: #IO L11N T1 SRCC 16 Sch=btn[2]
set property -dict { PACKAGE PIN B9
set property -dict { PACKAGE PIN B8
                                       IOSTANDARD LVCMOS33 } [get ports { a in[3] }]; #IO L12P T1 MRCC 16 Sch=btn[3]
## Switches
set property -dict { PACKAGE PIN A8
                                       IOSTANDARD LVCMOS33 } [qet ports { b in[0] }]; #IO L12N T1 MRCC 16 Sch=sw[0]
set property -dict { PACKAGE PIN Cll
                                       IOSTANDARD LVCMOS33 } [get ports { b in[1] }]; #IO L13P T2 MRCC 16 Sch=sw[1]
set property -dict { PACKAGE PIN C10
                                       IOSTANDARD LVCMOS33 } [get ports { b in[2] }]; #IO L13N T2 MRCC 16 Sch=sw[2]
set property -dict { PACKAGE PIN Al0
                                       IOSTANDARD LVCMOS33 } [get ports { b in[3] }]; #IO L14P T2 SRCC 16 Sch=sw[3]
## RGB LFDs
                                       IOSTANDARD LVCMOS33 } [qet ports { y out[0] }]; #IO L19N T3 VREF 35 Sch=led0 q
set property -dict { PACKAGE PIN F6
                                       IOSTANDARD LVCMOS33 } [qet ports { v out[1] }]; #IO L21P T3 DQS 35 Sch=led1 q
set property -dict { PACKAGE PIN J4
set property -dict { PACKAGE PIN J2
                                       IOSTANDARD LVCMOS33 } [qet ports { y out[2] }]; #IO L22N T3 35 Sch=led2 q
set property -dict { PACKAGE PIN H6
                                       IOSTANDARD LVCMOS33 } [get ports { y out[3] }]; #IO L24P T3 35 Sch=led3 g
set property -dict { PACKAGE PIN H5
                                       IOSTANDARD LVCMOS33 } [qet ports { y out[4] }]; #IO L24N T3 35 Sch=led[4]
```

### Outline



- 1 Laboratory Introduction
- 2 Simulation Testbenches
- 3 Combinational Logic Circuits
  - Multiplexer
  - Adder
  - Adder: common solutions
- 4 Homework

#### Adder: most common solution



```
library IEEE;
use IEEE.STD LOGIC 1164.ALL;
-- Uncomment the following library declaration if using
   arithmetic functions wath Signed or Unsigned values
use IEEE.NUMERIC STD.ALL;
entity adder 4b is
  generic (N : integer := 4);
  Port (a_in : in std logic vector(N-1 downto 0);
        b in : in std logic vector (N-1 downto 0);
        y out : out std logic vector(N downto 0) );
end adder 4b;
architecture rtl of adder 4b is
begin
y out <= std logic vector(unsigned('0' & a in) + unsigned('0' & b in));
end rtl:
```

### Adder: more elegant solution



```
entity adder 4b is
       generic (N : integer := 4):
   Port (a in : in std_logic_vector(N-1 downto 0);
                                 b in : in std logic vector (N-1 downto 0);
                                 y out : out std logic vector (N downto 0) );
 end adder 4b;
 architecture rtl of adder 4b is
 component adder 1b is
         Port (a in : in std logic:
                                 b in : in std logic;
                                 c in : in std logic;
                                y out : out std logic;
                                c out : out std logic);
 end component:
signal v an an1 : std logic vector(N downto 0):
 begin
 y an an1(0) <= '0';
y out(N) <= y an anl(N);
adders : for i in 0 to N-1 generate
         add: adder lb port map \frac{(a \text{ in} \Rightarrow a)}{(a \text{ in} \Rightarrow b)} in \frac{(a)}{(a)}, b in \frac{(a)}{(a)}, c in \frac{(a)}{(a)}, c out \frac{(a)}{(a)
 end generate adders:
 end rtl:
```

#### What remember ...



- In the first example you see the powerful of the VHDL code. Just with a code line you can replace the instantiation of a lot of logic gates and components. The work is done by the "compiler".
- The use of the **generic** is very common. It is essential in order to write a code reusable.
- **generic** together with **generate** statement is very useful.

### Outline



- 1 Laboratory Introduction
- 2 Simulation Testbenches
- 3 Combinational Logic Circuits
  - Multiplexer
  - Adder
  - Adder: common solutions
- 4 Homework

### Suggested exercises



- Redo 1,2,3, ..., N times the exercises. Or finish them.
- Get the code more complicated.

Use a mux 2-1 and a 3 bit adder in order to implement an adder-subtractor.

If BTN0 is '0' the circuit works as an adder else as a subtractor.

a\_in is drived by BTN1, BTN2 and BTN3.

b\_in is drived by SW1,SW2 and SW3.

The output is represented in LD4, LD3, LD2, LD1 and LD0.

LD4 represent the sign bit, that is LD4 = '1' means negative number else positive number.

**Hint**: exploit the two's complement properties.